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Microsoft Knowledge Base Article - 153307 

HOWTO: Call Microsoft Excel Macros That Take Parameters 

A p plies To 

This article was previously published under Q153307 
SUMMARY 

Using Automation, you can manipulate Microsoft Excel. It Is possible to call macro procedures that are stored in Microsoft 

Excel Workbooks by using the Run method of the Microsoft Excel Application object. Microsoft Excel macro procedures that 
take parameters cause a slight change in the syntax. Included below is a code sample showing how to call a Microsoft Excel 
macro procedure from Visiiai Basic 

MORE INFORMATION 
Step-by-Slep Example 

1. Start a new Project in Visual Basic. Forml is created by default 

2. Place a CommandButton on i=<>rml. 

3. In the General Declarations section of i=orml, enter tills code: 

Option Explicit 

Private Sub Cotninandl_Click () 
Dim oExcelApp As Object 

' Create a reference to the currently running excel application 
Set oExcelApp = GetObject(, "Excel . application") 
' Make the Excel Application Visible. 
oExcelApp. Visible = True 
' Run the excel procedure 
OExcelApp. run "proc", "David", 30 
Bad Sub 



4. Start Microsoft Excel. Bookl Is created by default. 

5. Add a new module to the workbook. 

For Excel 5.0 and 7.0: From the Insert menu, choose Macro, and select the Module Option. This will give you a new 
module stee^ Modulel. 

For Excel 97 and later: Press ALT+Fll to Start the Visual Basic Editor. CSkk Module on the Insert menu. 

6. In Modulel, type the following code: 

Sub Proc (sParaml As String, iParam2 As Integer) 

MsgBox sParaml & " is " & iParam2 & " Years Old" 
End Sub 



7. Leave the workbook open in Microsoft Excel and switch to your project in Visual Basic. 

8. From Visual Basic, press F5 to run the project Click the command button, and you should see a diatog box appear 
writh the tie]« 'David is 30 years old" in it. 

REFERENCES 

For more information about using Visual Basic to Automate Excel, see the following: 
Office Automation 
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The Informattdn in this aptiele applies 

• Microsoft ExE^ 2000 

• Microsoft Visual Basic Learning Edition for Windows 5.0 

• Microsoft Visual Basic Learning Edition for Windows 6.0 

• Microsoft Visual Basic Professional Edition for Windows 5.0 

• Microsoft Visual Basic Professional Edition for Windows 6.0 

• Microsoft Visual Basic Enterprise Edition for Windows 5.0 

• Microsoft Visual Basic Enterprise Edition for Windows 6.0 

• Microsoft Visual Basic Standard Edition, 32-bit, for Windows 4.0 

• Microsoft Visual Basic Professional Edition, 16-bit, for Windows 4.0 

• Microsoft Visual Basic Professional Edition, 32-blt, for Windows 4.0 

• Microsoft Visual Basic Enterprise Edition, 16-bit, for Windows 4.0 

• Microsoft Visual Basic Enterprise Edition, 32-M, f&tWmSom 4.0 

• Microsoft Visual Basic for Applications 5.0 

• Microsoft Excel 2002 

• Microsoft Excel 97 for Windows 
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